草庐IT

php - preg_match 的正则表达式

全部标签

ruby-on-rails - 简单的正则表达式——用空格替换下划线

嘿,我正在编写我的第一个Rails应用程序,我正在尝试用空格替换传入ID名称中的下划线,如下所示:之前:test_string之后:测试字符串我该怎么做?对不起,如果这是一个有点愚蠢的问题,我对正则表达式不是很熟悉...... 最佳答案 str.gsub!(/_/,'')gsub代表“全局替换”,感叹号表示它将更改字符串本身,而不仅仅是返回替换后的字符串。您也可以使用String#tr!在没有正则表达式的情况下执行此操作:str.tr!('_','') 关于ruby-on-rails-简

ruby - 如何从字符串正则表达式 ruby​​ 中获取所有数字

如何在ruby​​中使用正则表达式从诸如“Lorem123ipsum456879”=>“123456879”这样的句子字符串中获取所有数字? 最佳答案 只需替换所有其他内容即可。result=subject.gsub(/[^\d]/,'') 关于ruby-如何从字符串正则表达式ruby​​中获取所有数字,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/8019702/

用于匹配 url 的 Ruby 正则表达式

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicates:RegextomatchURLregextoremovethewebpagepartofaurlinruby我正在寻找一个正则表达式来解析文件中的所有url。我尝试了谷歌搜索后得到的许多正则表达式,但在一种或另一种情况下都失败了。我的想法是写一个在开始时检查http或https的存在,它会匹配所有内容,直到它看到一个空格。有什么想法吗?注意:我不需要解析url,但需要从文件中删除所有url,或者至少使其不可读。

ruby - 正则表达式——Ruby 与 Perl

我注意到我的Ruby(1.9)脚本中存在一些极度延迟,经过一些挖掘后,它归结为正则表达式匹配。我在Perl和Ruby中使用以下测试脚本:Perl:$fname=shift(@ARGV);open(FILE,"){if(/(.*?)\|.*?SENDINGREQUEST.*?TID=(.*?),/){print"$1:$2\n";}}ruby:f=File.open(ARGV.shift)while(line=f.gets)if/(.*?)\|.*?SENDINGREQUEST.*?TID=(.*?),/.match(line)puts"#{$1}:#{$2}"endend我对两个脚本使

ruby - 在 Ruby gsub block (正则表达式)中使用命名捕获组

我正在尝试在Ruby的block内使用命名捕获组。$1仍然有效,但我想使用我提供的名称来引用它。"foo/(bar)".gsub(/(?\(.*?\))/x)do|match|puts"$1=#{$1}and$my_word=#{$my_word}"end预期:$1=(bar)and$my_word=(bar) 最佳答案 你在找"foo/(bar)".gsub(/(?\(.*?\))/x)do|match|puts"$1=#{$1}and$my_word=#{$~[:my_word]}"end

ruby - 让星形正则表达式运算符失败

我不确定是我脑子坏了还是我只是想得太用力了。以下代码来自RubyKoans中的about_regular_expressions。deftest_asterisk_means_zero_or_moreassert_equal"abb","abbcccddddeeeee"[/ab*/]assert_equal"a","abbcccddddeeeee"[/az*/]assert_equal"","abbcccddddeeeee"[/z*/]#THINKABOUTIT:##Whenwould*failtomatch?end如何让*使匹配失败?当我说失败时,我假设他们的意思是他们希望asser

用于每四个字符拆分的 Ruby 正则表达式不起作用

我正在尝试每四个字符拆分一个相当大的字符串。这就是我正在尝试的方式:big_string.split(/..../)这会生成一个nil数组。据我所知,这应该有效。当我将它插入onlinerubyregextest时它甚至会这样做. 最佳答案 试试扫描:$irb>>"abcd1234beefcake".scan(/..../)=>["abcd","1234","beef","cake"]或>>"abcd1234beefcake".scan(/.{4}/)=>["abcd","1234","beef","cake"]如果字符数不能被4整

ruby - 如何在 Nokogiri 中使用正则表达式搜索匹配特定开头的文本?

给定:require'rubygems'require'nokogiri'value=Nokogiri::HTML.parse(AFooBCBarDEF"HTML_END我想做一些我可以在Hpricot中做的事情:divs=value.search('//div[@id^="para-"]')如何对XPath样式的元素进行模式搜索?我在哪里可以找到对我有帮助的文档?我没有在rdoc中看到这个。 最佳答案 使用xpath函数starts-with:value.xpath('//p[starts-with(@id,"para-")]')

ruby-on-rails - Ruby 2.0.0 字符串#Match ArgumentError : invalid byte sequence in UTF-8

我经常看到这种情况,但还没有想出一个优雅的解决方案。如果用户输入包含无效的字节序列,我需要能够让它不引发异常。例如:#@raw_responsecomesfromuserandcontainsinvalidUTF-8#forexample:@raw_response="\xBF"regex.match(@raw_response)ArgumentError:invalidbytesequenceinUTF-8已经问了很多类似的问题,结果似乎是对字符串进行编码或强制编码。然而,这些都不适合我:regex.match(@raw_response.force_encoding("UTF-8"

ruby - 另一种方法而不是转义正则表达式模式?

通常当我的正则表达式模式看起来像这样时:http://www.microsoft.com/然后我必须像这样逃避它:string.match(/http:\/\/www\.microsoft\.com\//)有没有其他方法而不是像那样转义它?我希望能够像这样使用它http://www.microsoft.com,因为我不想转义所有模式中的所有特殊字符。 最佳答案 Regexp.new(Regexp.quote('http://www.microsoft.com/'))Regexp.quote简单地转义任何具有特殊正则表达式含义的字符;